//字符串压缩。利用字符重复出现的次数，编写一种方法，实现基本的字符串压缩功能。比如，字符串aabcccccaaa会变为a2b1c5a3。若“压缩”后的字符串没
//有变短，则返回原先的字符串。你可以假设字符串中只包含大小写英文字母（a至z）。
//
// 示例1:
//
//
// 输入："aabcccccaaa"
// 输出："a2b1c5a3"
//
//
// 示例2:
//
//
// 输入："abbccd"
// 输出："abbccd"
// 解释："abbccd"压缩后为"a1b2c2d1"，比原字符串长度更长。
//
//
// 提示：
//
//
// 字符串长度在[0, 50000]范围内。
//
// Related Topics 双指针 字符串 👍 107 👎 0


//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public String compressString(String S) {
        int length = S.length();

        if (length == 0) {
            return S;
        }

        StringBuilder sb = new StringBuilder();
        int count = 1;
        char c = S.charAt(0);

        for (int r = 1; r < length; r++) {
            if (c == S.charAt(r)) {
                count++;
            } else {
                sb.append(c);
                sb.append(count);
                c = S.charAt(r);
                count = 1;
            }
        }

        sb.append(c);
        sb.append(count);

        return sb.length() >= length ? S : sb.toString();
    }
}
//leetcode submit region end(Prohibit modification and deletion)
